package com.zy.explore.goods.interfaces.feign;

import com.zy.explore.common.interfaces.frm.CommonIdFrm;
import com.zy.explore.common.interfaces.frm.CommonIdsFrm;
import com.zy.explore.goods.infrastructure.constant.ProjectConstant;
import com.zy.explore.goods.interfaces.frm.GoodsFrm;
import com.zy.explore.goods.interfaces.vo.GoodsVO;

import com.zy.explore.common.interfaces.vo.PageVO;

import io.swagger.annotations.ApiOperation;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;

import java.util.List;

/**
 * 商品表(表t_goods)Feign服务
 *
 * @author 中国印
 * @date 2021-09-21 00:49:01
 */
@FeignClient(value = ProjectConstant.SERVICE_NAME, path = "/goods", contextId = ProjectConstant.SERVICE_NAME + ".goods")
public interface GoodsFeign {

    /**
     * 新增数据
     *
     * @param frm 待新增的frm对象
     * @return 成功返回新增后的VO对象，失败返回null
     */
    @ApiOperation("新增数据")
    @PostMapping("/insert")
    GoodsVO insert(@RequestBody @Validated GoodsFrm frm);

    /**
     * 删除数据
     *
     * @param frm 主键frm对象
     * @return 1:删除成功 其他:删除失败
     */
    @ApiOperation("删除数据")
    @PostMapping("/delete")
    Integer delete(@RequestBody @Validated CommonIdFrm frm);

    /**
     * 更新数据
     *
     * @param frm 待更新的frm对象
     * @return 成功返回更新后的VO对象，失败返回null
     */
    @ApiOperation("更新数据")
    @PostMapping("/update")
    GoodsVO update(@RequestBody @Validated GoodsFrm frm);

    /**
     * 通过主键查询单条数据
     *
     * @param frm 主键Frm对象
     * @return 成功返回对应ID的VO对象，失败返回null
     */
    @ApiOperation("根据主键查询数据")
    @PostMapping("/findById")
    GoodsVO findById(@RequestBody @Validated CommonIdFrm frm);

    /**
     * 通过主键批量查询数据集合
     *
     * @param frm 主键集合Frm对象
     * @return 成功返回对应ID的VO对象，失败返回空集合
     */
    @ApiOperation("根据主键集批量查询数据")
    @PostMapping("/findByIds")
    List<GoodsVO> findByIds(@RequestBody @Validated CommonIdsFrm frm);

    /**
     * 根据条件获取数据集
     *
     * @param frm 查询条件对象
     * @return 成功返回满足条件的数据集合，失败返回空集合
     */
    @ApiOperation("根据条件查询数据集")
    @PostMapping("/getList")
    List<GoodsVO> getList(@RequestBody @Validated GoodsFrm frm);

    /**
     * 根据条件查询数据分页
     *
     * @param frm 查询条件参数
     * @return 成功返回满足条件的分页，失败返回空页
     */
    @ApiOperation("根据条件查询数据分页")
    @PostMapping("/getPageInfo")
    PageVO<GoodsVO> getPageInfo(@RequestBody @Validated GoodsFrm frm);

}
